home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1996 March / EnigmA AMIGA RUN 05 (1996)(G.R. Edizioni)(IT)[!][issue 1996-03][Skylink CD IV].iso / earcd / gnu / gnpltsrc.lha / 0FAQ < prev    next >
Text File  |  1996-01-22  |  55KB  |  1,329 lines

  1. Archive-name: graphics/gnuplot-faq
  2. Version: Tue Aug 22 04:23:01 CES 1995
  3. Posting-frequency: every 14 days
  4. URL: http://www.uni-karlsruhe.de/~ig25/gnuplot-faq/
  5.  
  6.    comp.graphics.apps.gnuplot
  7.  
  8.         COMP.GRAPHICS.APPS.GNUPLOT FAQ (FREQUENT ANSWERED QUESTIONS)
  9.  
  10.    This is the FAQ (Frequently Answered Questions) list of the
  11.    comp.graphics.apps.gnuplot newsgroup, which discusses the gnuplot
  12.    program for plotting 2D - and 3D - graphs.
  13.  
  14.    Most of the information in this document came from public discussion
  15.    on comp.graphics.apps.gnuplot; quotations are believed to be in the
  16.    public domain.
  17.  
  18.    If you are reading this via WWW, and you can't access the individual
  19.    pages, please select here, then try again.
  20.  
  21.    Here's a list of the questions. If you are looking for the answer for
  22.    a specific question, look for the string Qx.x: at the beginning of a
  23.    line, with x.x being the question number. Sections in this FAQ are
  24.      * 0. Meta-Questions
  25.      * 1. General Information
  26.      * 2. Setting it up
  27.      * 3. Working with it
  28.      * 4. Wanted features
  29.      * 5. Miscellaneous
  30.      * 6. Making life easier
  31.      * 7. Known problems
  32.      * 8. Credits
  33.  
  34.  
  35.  
  36. Questions:
  37.  
  38.   SECTION 0: META - QUESTIONS
  39.      * Q0.1: Where do I get this document?
  40.      * Q0.2: Where do I send comments about this document?
  41.  
  42.   SECTION 1: GENERAL INFORMATION
  43.      * Q1.1: What is gnuplot?
  44.      * Q1.2: How did it come about and why is it called gnuplot?
  45.      * Q1.3: Does gnuplot have anything to do with the FSF and the GNU
  46.        project?
  47.      * Q1.4: What does gnuplot offer?
  48.      * Q1.5: Is gnuplot suitable for batch processing?
  49.      * Q1.6: Can I run gnuplot on my computer?
  50.  
  51.   SECTION 2: SETTING IT UP
  52.      * Q2.1: What is the current version of gnuplot?
  53.      * Q2.2: Where can I get gnuplot?
  54.      * Q2.3: How do I get gnuplot to compile on my system?
  55.      * Q2.4: What documentation is there, and how do I get it?
  56.  
  57.   SECTION 3: WORKING WITH IT
  58.      * Q3.1: How do I get help?
  59.      * Q3.2: How do I print out my graphs?
  60.      * Q3.3: How do I include my graphs in <word processor>?
  61.      * Q3.4: How do I post-process a gnuplot graph?
  62.  
  63.   SECTION 4: WANTED FEATURES
  64.      * Q4.0: What's new in gnuplot 3.6?
  65.      * Q4.1: Does gnuplot have hidden line removal?
  66.      * Q4.2: Does gnuplot support bar-charts/histograms/boxes?
  67.      * Q4.3: Does gnuplot support multiple y-axes on a single plot?
  68.      * Q4.4: Can I put multiple plots on a single page?
  69.      * Q4.5: Can I put both data files and commands into a single file?
  70.      * Q4.6: Can I put Greek letters and super/subscripts into my labels?
  71.      * Q4.7 Can I do 1:1 scaling of axes?
  72.      * Q4.8: Can I put tic marks for x and y axes into 3d plots?
  73.      * Q4.9: Does gnuplot support a driver for <graphics format>?
  74.      * Q4.10: Can I put different text sizes into my plots?
  75.      * Q4.11: How do I modify gnuplot?
  76.      * Q4.12: How do I skip data points?
  77.  
  78.   SECTION 5: MISCELLANEOUS
  79.      * Q5.1: I've found a bug, what do I do?
  80.      * Q5.2: Can I use gnuplot routines for my own programs?
  81.      * Q5.3: What extensions have people made to gnuplot? Where can I get
  82.        them?
  83.      * Q5.4: Can I do heavy-duty data processing with gnuplot?
  84.      * Q5.5: I have ported gnuplot to another system, or patched it. What
  85.        do I do?
  86.      * Q5.6: I want to help in developing gnuplot 3.6. What can I do?
  87.  
  88.   SECTION 6: MAKING LIFE EASIER
  89.      * Q6.1: How do I plot two functions in non-overlapping regions?
  90.      * Q6.2: How do I run my data through a filter before plotting?
  91.      * Q6.3: How do I make it easier to use gnuplot with LaTeX?
  92.      * Q6.4: How do I save and restore my settings?
  93.      * Q6.5: How do I plot lines (not grids) using splot?
  94.      * Q6.6: How do I plot a function f(x,y) which is bounded by other
  95.        functions in the x-y plain?
  96.      * Q6.7: How do I get rid of <feature in a plot>?
  97.      * Q6.8: How do I call gnuplot from my own programs ?
  98.  
  99.   SECTION 7: KNOWN PROBLEMS
  100.      * Q7.1: Gnuplot is not plotting any points under X11! How come?
  101.      * Q7.2: My isoline data generated by a Fortran program is not
  102.        handled correctly. What can I do?
  103.      * Q7.3: Why does gnuplot ignore my very small numbers?
  104.      * Q7.4: Gnuplot is plotting nothing when run via gnuplot <filename>!
  105.        What can I do?
  106.      * Q7.5: My formulas are giving me nonsense results! What's going on?
  107.      * Q7.6: My Linux gnuplot complains about a missing gnuplot_x11. What
  108.        is wrong?
  109.  
  110.   SECTION 8: CREDITS
  111.  
  112.   SECTION 0: META-QUESTIONS.
  113.  
  114.     Q0.1: Where do I get this document?
  115.           This document is posted about once every two weeks to the
  116.           newsgroups comp.graphics.apps.gnuplot, comp.answers and
  117.           news.answers. Like many other FAQ's, its newest (plaintext)
  118.           version is available via anonymous ftp from
  119.           ftp://rtfm.mit.edu/pub/usenet/news.answers/graphics/gnuplot-f
  120.           aq.
  121.  
  122.           If you have access to the WWW, you can get the newest version
  123.           of this document from
  124.           http://www.uni-karlsruhe.de/~ig25/gnuplot-faq/
  125.  
  126.    Q0.2: Where do I send comments about this document?
  127.           Send comments, suggestions etc. via e-mail to Thomas Koenig,
  128.           Thomas.Koenig@ciw.uni-karlsruhe.de or ig25@dkauni2.bitnet.
  129.  
  130.  
  131.  
  132.   SECTION 1: GENERAL INFORMATION
  133.  
  134.     Q1.1: What is gnuplot?
  135.           Gnuplot is a command-driven interactive function plotting
  136.           program. It can be used to plot functions and data points in
  137.           both two- and three- dimensional plots in many different
  138.           formats, and will accommodate many of the needs of today's
  139.           scientists for graphic data representation. Gnuplot is
  140.           copyrighted, but freely distributable; you don't have to pay
  141.           for it.
  142.  
  143.    Q1.2: How did it come about and why is it called gnuplot?
  144.           The authors of gnuplot are:
  145.  
  146.           Thomas Williams, Colin Kelley, Russell Lang, Dave Kotz, John
  147.           Campbell, Gershon Elber, Alexander Woo and many others.
  148.  
  149.           The following quote comes from Thomas Williams:
  150.  
  151.      I was taking a differential equation class and Colin was taking
  152.      Electromagnetics, we both thought it'd be helpful to visualize the
  153.      mathematics behind them. We were both working as sys admin for an EE
  154.      VLSI lab, so we had the graphics terminals and the time to do some
  155.      coding. The posting was better received than we expected, and
  156.      prompted us to add some, albeit lame, support for file data.
  157.  
  158.      Any reference to GNUplot is incorrect. The real name of the program
  159.      is "gnuplot". You see people use "Gnuplot" quite a bit because many
  160.      of us have an aversion to starting a sentence with a lower case
  161.      letter, even in the case of proper nouns and titles. Gnuplot is not
  162.      related to the GNU project or the FSF in any but the most peripheral
  163.      sense. Our software was designed completely independently and the
  164.      name "gnuplot" was actually a compromise. I wanted to call it
  165.      "llamaplot" and Colin wanted to call it "nplot." We agreed that
  166.      "newplot" was acceptable but, we then discovered that there was an
  167.      absolutely ghastly pascal program of that name that the Computer
  168.      Science Dept. occasionally used. I decided that "gnuplot" would make
  169.      a nice pun and after a fashion Colin agreed.
  170.  
  171.    Q1.3: Does gnuplot have anything to do with the FSF and the GNU
  172.           project?
  173.           Gnuplot is neither written nor maintained by the FSF. It is not
  174.           covered by the General Public License, either.
  175.  
  176.           However, the FSF has decided to distribute gnuplot as part of
  177.           the GNU system, because it is useful, redistributable software.
  178.  
  179.    Q1.4: What does gnuplot offer?
  180.  
  181.           + Plotting of two-dimensional functions and data points in many
  182.             different styles (points, lines, error bars)
  183.           + plotting of three-dimensional data points and surfaces in
  184.             many different styles (contour plot, mesh).
  185.           + support for complex arithmetic
  186.           + self - defined functions
  187.           + support for a large number of operating systems, graphics
  188.             file formats and devices
  189.           + extensive on-line help
  190.           + labels for title, axes, data points
  191.           + command line editing and history on most platforms
  192.  
  193.    Q1.5: Is gnuplot suitable for batch processing?
  194.           Yes. You can read in files from the command line, or you can
  195.           redirect your standard input to read from a file. Both data and
  196.           command files can be generated automatically, from data
  197.           acquisition programs or whatever else you use.
  198.  
  199.    Q1.6: Can I run gnuplot on my computer?
  200.           Gnuplot is available for a number of platforms. These are: Unix
  201.           (X11 and NeXTSTEP), VAX/VMS, OS/2, MS-DOS, Amiga, MS-Windows,
  202.           OS-9/68k, Atari ST and the Macintosh. Modifications for NEC
  203.           PC-9801 are said to exist (where?).
  204.  
  205.  
  206.  
  207.   SECTION 2: SETTING IT UP
  208.  
  209.     Q2.1: What is the current version of gnuplot?
  210.           The current version of gnuplot is 3.5, which is a bugfix
  211.           release over 3.4.
  212.  
  213.           Version 3.6 is in beta status. Please note that this is still
  214.           unstable, and may not compile correctly on your system.
  215.  
  216.    Q2.2: Where can I get gnuplot?
  217.           All of the later addresses refer to ftp sites. Please note that
  218.           it is preferable for you to use the symbolic name, rather than
  219.           the IP address given in brackets, because that address is much
  220.           more subject to change.
  221.  
  222.           The official distribution site for the gnuplot source is
  223.           ftp.dartmouth.edu [129.170.16.4], the file is called
  224.           /pub/gnuplot/gnuplot3.5.tar.Z. Official mirrors of that
  225.           distribution are (for Australia) monu1.cc.monash.edu.au
  226.           [130.194.1.101] and (for Europe) irisa.irisa.fr
  227.           [131.254.254.2]. You can also get it from your friendly
  228.           neighbourhood comp.sources.misc archive.
  229.  
  230.           MS-DOS and MS-Windows binaries are available from
  231.  
  232.           + oak.oakland.edu (North America) [141.210.10.117] as
  233.             /Simtel/msdos/plot/gpt35*.zip,
  234.           + garbo.uwasa.fi (Europe) [128.214.87.1] as /pc/plot/gpt35*.zip
  235.             and
  236.           + archie.au (Australia) [139.130.4.6] as
  237.             micros/pc/oak/plot/gpt35*.zip.
  238.  
  239.    The files are: gpt35doc.zip, gpt35exe.zip, gpt35src.zip and
  240.           gpt35win.zip.
  241.  
  242.           There is a special MS-DOS version for 386 or better processors;
  243.           it is available from the official gnuplot sites as DOS34.zip.
  244.  
  245.           OS/2 2.x binaries are at ftp-os2.nmsu.edu [128.123.35.151], in
  246.           /os2/2.x/unix/gnuplt35.zip.
  247.  
  248.           Amiga sources and binaries are available from ftp.wustl.edu
  249.           [128.252.135.4] as /pub/aminet/util/gnu/gnuplot-3.5.lha; there
  250.           are numerous mirrors of this distribution, for example
  251.           ftp.uni-kl.de, oes.orst.edu or ftp.luth.se.
  252.  
  253.           The NeXTSTEP front end can be found at sonata.cc.purdue.edu and
  254.           cs.orst.edu.
  255.  
  256.           A version for OS-9/68K can be found at cabrales.cs.wisc.edu
  257.           [128.105.36.20] as /pub/OSK/GRAPHICS/gnuplot32x.tar.Z; it
  258.           includes both X-Windows and non - X-windows versions.
  259.  
  260.           There is a version for the Macintosh at
  261.           ftp://ftp.ee.gatech.edu/pub/mac/gnuplot/ which includes
  262.           binaries for 68000-based Macs with and without FPU and native
  263.           support for PowerMacs.
  264.  
  265.           Versions for the Atari ST and TT, which include some GEM
  266.           windowing support, are available from
  267.           ftp://ftp.uni-kl.de/pub/atari/graphics/, as gplt35st.zip and
  268.           gplt35tt.zip. They work best under MiNT.
  269.  
  270.           Executable files, plus documentation in Japanese, exist for the
  271.           X680x0 on
  272.           ftp://ftp.csis.oita-u.ac.jp/pub/x68k/fj.binaries.x68000/vol2.
  273.  
  274.  
  275.           People without ftp access can use an ftp-mail server; send a
  276.           message saying 'help' to bitftp@pucc.bitnet (for BITNET only)
  277.           or to ftpmail@ftp.dartmouth.edu.
  278.  
  279.           For a uuencoded copy of the the gnuplot sources (compressed tar
  280.           file), send this as the body of a message to
  281.           ftpmail@ftp.dartmouth.edu:
  282.  
  283.  
  284.         open
  285.         cd pub/gnuplot
  286.         mode binary
  287.         get gnuplot3.5.tar.Z
  288.         quit
  289.  
  290.    If you have some problem, you might need to stick
  291.  
  292.  
  293.         reply-to  <your-email-address-here>
  294.  
  295.    before all the above.
  296.  
  297.           It is a good idea to look for a nearby ftp site when
  298.           downloading things. You can use archie for this. See if an
  299.           archie client is installed at your system (by simply typing
  300.           archie at the command prompt), or send mail to archie@sura.net
  301.           with the word 'help' in both the subject line and the body of
  302.           the mail. However, be aware that the version you find at a near
  303.           ftp site may well be out of date; check the last modification
  304.           date and the number of bytes against the newest release at one
  305.           of the official servers.
  306.  
  307.           You can obtain a beta release of gnuplot 3.6 from
  308.           ftp://cmpc1.phys.soton.ac.uk/pub/.
  309.  
  310.    Q2.3: How do I get gnuplot to compile on my system?
  311.           As you would any other installation. Read the files README and
  312.           README.Install, edit the Makefile according to taste, and run
  313.           make or whatever is suitable for your operating system.
  314.  
  315.           If you get a complaint about a missing file libplot.a or
  316.           something similar when building gnuplot for X11, remove
  317.           -DUNIXPLOT from the TERMFLAGS= line, remove -lplot from the
  318.           DTBS= line and run again. If you are making X11 on a sun, type
  319.           'make x11_sun'.
  320.  
  321.           For compiling gnuplot under Irix 5.2 and Irix 5.3, there is a
  322.           patch in the file lvs.zip in the contrib directory at
  323.           ftp.dartmouth.edu.
  324.  
  325.    Q2.4: What documentation is there, and how do I get it?
  326.           The documentation is included in the source distribution. Look
  327.           at the docs subdirectory, where you'll find
  328.  
  329.           + a Unix man page, which says how to start gnuplot
  330.           + a help file, which also can be printed as a manual
  331.           + a tutorial on using gnuplot with LaTeX
  332.           + a quick reference summary sheet for TeX only
  333.  
  334.    PostScript copies of the documentation can be ftp'd from
  335.           ftp.dartmouth.edu, in pub/gnuplot, as manual.ps.Z and
  336.           tutorial.ps.Z
  337.  
  338.           Andy Liaw and Dick Crawford have written a 16-page user's
  339.           guide. It is available from ftp://picard.tamu.edu/pub/gnuplot/
  340.           as gptug.tex (also get example.tex from the same directory),
  341.           gptug.dvi or gptug.ps.
  342.  
  343.           At the same site, there's a two- page instruction sheet for the
  344.           enhpost PostScript driver (see Q4.6 ) as enhpost.guide.ps and a
  345.           short guide to gnuplot PostScript files, as gp-ps.doc.
  346.  
  347.           A Chinese translation of the gnuplot manual can be found on
  348.           ftp://servers.nctu.edu.tw/misc/environment/NCTU_EV/classnote/
  349.           gnuplot.ps.gz .
  350.  
  351.           There is a WWW hompepage for gnuplot at
  352.           http://www.cs.dartmouth.edu/gnuplot_info.html, which includes
  353.           the reference manual and a demo.
  354.  
  355.           There are two more Chinese documents about gnuplot: a 72 - page
  356.           User's guide
  357.           ftp://phi.sinica.edu.tw/pub/aspac/doc/94/94002.ps.gz and a 28
  358.           - page Touring Guide
  359.           ftp://phi.sinica.edu.tw/pub/aspac/doc/95/95006.ps.gz. Both
  360.           documents are in PostScript format and gzipped.
  361.  
  362.  
  363.  
  364.   SECTION 3: WORKING WITH IT
  365.  
  366.     Q3.1: How do I get help?
  367.           Give the 'help' command at the initial prompt. After that, keep
  368.           looking through the keywords. Good starting points are 'plot'
  369.           and 'set'.
  370.  
  371.           Read the manual, if you have it.
  372.  
  373.           Look through the demo subdirectory; it should give you some
  374.           ideas.
  375.  
  376.           Ask your colleagues, the system administrator or the person who
  377.           set up gnuplot.
  378.  
  379.           Post a question to comp.graphics.apps.gnuplot or send mail to
  380.           the gatewayed mailing list info-gnuplot@dartmouth.edu. If you
  381.           want to subscribe to the mailing list, send a mail to
  382.           majordomo@dartmouth.edu with the body of the message being
  383.           'subscribe info-gnuplot'. Please don't do this if you can get
  384.           comp.graphics.apps.gnuplot directly. If you pose a question
  385.           there, it is considered good form to solicit e-mail replies and
  386.           post a summary.
  387.  
  388.    Q3.2: How do I print out my graphs?
  389.           The kind of output produced is determined by the 'set terminal'
  390.           command; for example, 'set terminal postscript' will produce
  391.           the graph in PostScript format. Output can be redirected using
  392.           the 'set output' command.
  393.  
  394.           As an example, the following prints out a graph of sin(x) on a
  395.           Unix machine running the X Window system.
  396.  
  397.  
  398.         gnuplot> plot [-6:6] sin(x)
  399.         gnuplot> set terminal postscript
  400.         Terminal type set to 'postscript'
  401.         Options are 'landscape monochrome "Courier" 14'
  402.         gnuplot> set output "sin.ps"
  403.         gnuplot> replot
  404.         gnuplot> set output              # set output back to default
  405.         gnuplot> set terminal x11        # ditto for terminal type
  406.         gnuplot> ! lp -ops sin.ps        # print PS File (site dependent)
  407.         request id is lprint-3433 (standard input)
  408.         lp: printed file sin.ps on fg20.rz.uni-karlsruhe.de (5068 Byte)
  409.         !
  410.         gnuplot>
  411.  
  412.    Q3.3: How do I include my graphs in <word processor>?
  413.           Basically, you save your plot to a file in a format your word
  414.           processor can understand (using "set term" and "set output",
  415.           see above), and then you read in the plot from your word
  416.           processor.
  417.  
  418.           Details depend on the kind of word processor you use; use "set
  419.           term" to get a list of available file formats.
  420.  
  421.           Many word processors can use Encapsulated PostScript for
  422.           graphs. This can be generated by the "set terminal postscript
  423.           eps" command. Most MS-DOS word processors understand HPGL
  424.           (terminal type hpgl).
  425.  
  426.           With TeX, it depends on what you use to print your dvi files.
  427.           If you use dvips or dvi2ps, you can use Encapsulated
  428.           PostScript. For emTeX (popular for MS-DOS), you can use emTeX,
  429.           otherwise use the LaTeX terminal type, which generates a
  430.           picture environment.
  431.  
  432.           If nothing else helps, try using the pgm or ppm format and
  433.           converting it to a bitmap format your favourite word processor
  434.           can understand. An invaluable tool for this is Jef Poskanzer's
  435.           PBMPLUS package.
  436.  
  437.           The PBMPLUS package is available in the contrib distribution
  438.           for the X Window System. The original site for this is
  439.           ftp://ftp.x.org/contrib/. There are many mirrors, e.g.
  440.           ftp://ftp.th-darmstadt.de/pub/X11/contrib/ or .
  441.           ftp://sunsite.unc.edu/pub/X11/contrib/.
  442.  
  443.           The most recent release of pbm by the author is dated December
  444.           91 and is called pbmplus10dec91.tar.Z
  445.  
  446.           There is new version including lots of patches from the net
  447.           that is not maintained by the author called netpbm, with the
  448.           newest version called netpbm-7dec1993.tar.gz.
  449.  
  450.           Check archie (see Q2.2 ) for an archive site near you.
  451.  
  452.    Q3.4: How do I post-process a gnuplot graph?
  453.           This depends on the terminal type you use.
  454.  
  455.           You can use the terminal type fig (you may need to recompile
  456.           gnuplot to enable this terminal type, by putting #define FIG
  457.           into <term.h>), and use the xfig drawing program to edit the
  458.           plot afterwards.
  459.  
  460.           For PostScript output, you may be able to use the pstotgif
  461.           script (which calls GhostScript) to convert PostScript into the
  462.           format of the tgif drawing program. Tgif is also able to save
  463.           in PostScript format.
  464.  
  465.           Both tgif and xfig can be obtained from the X Window contrib
  466.           distribution (see Q3.3).
  467.  
  468.           Another possibility for modifying PostScript output appears to
  469.           be IslandDraw, a commercial drawing program for UNIX
  470.           workstations.
  471.  
  472.  
  473.  
  474.   SECTION 4: WANTED FEATURES
  475.  
  476.     Q4.0: What's new in gnuplot 3.6?
  477.           Here's the WhatsNew file of the current beta release,
  478.           patchlevel 213.
  479.  
  480.  
  481. What's new in 3.6 ?
  482.  
  483. Still to do
  484.   Many terminals to be converted to new layout
  485.   someone has contributed a new hidden-line-removal
  486.   '-' as load filename / command-line param
  487.   key for splot with contour is ugly
  488.   timeseries stuff has got broken (well, non-portable code)
  489.   terminals are no longer allowed to do their own scaling
  490.  
  491. Plus quite a few contributed patches that I haven't yet installed (sorry)
  492.  
  493. in 194
  494.   multiplot for splot
  495.  
  496. in 188
  497.   os9 port
  498.   set xrange [] reverse writeback
  499.   allow mix of co-ordinate systems within an arrow/label posn
  500.   initial multiplot support
  501.   - doesn't yet check that terminal is capable, but there is a
  502.     flags field added to the terminal entry to tell gnuplot about this.
  503.     also, suspend() / resume() entry points which are to be called
  504.     between plots of a multiplot.
  505.  
  506. in 178
  507.    arbitrary length/number of columns in datafile
  508.    accept double/quad-precision fortran numbers (1.23{dDqQ}4)
  509.    - but not in scanf format string
  510.    undefined fit parameters start at 1 rather than 1e-30
  511.    - more chance of convergence / less change of unitary matrix
  512.    WIN32 / Win-NT support
  513.    table output can be read back in for data splot
  514.    - hence gnuplot can be used to dgrid a datafile and write it out
  515.    set missing 'string'
  516.    - nominate a token as standing for missing values in datafile
  517.    - not yet added to documentation
  518.    updates to time-series stuff (so it doesn't break at 2000)
  519.    - except it has become horribly non-portable :-(
  520.    split graph3d.c into util3d.c and hidden3d.c
  521.  
  522. in 166
  523.    set bar <size>
  524.    - a number rather than just small or large
  525.    allow different linetypes for grid at major and minor tics
  526.    a few more set no* commands for consistency.
  527.    initial go at implementing tic mirrors and axes for splot
  528.    - no ztic axis yet (or no zzeroaxis)
  529.    - tics on axes are not hidden by surface
  530.    attempt to make sin(x) behave as expected when set angle degrees
  531.    - gives answers if x is complex, but I dont know if they are correct
  532.      - acos(cos(x)) seems to give x, so at least its consistent
  533.    - fix a bug which made acos(cos({0,1})) undefined
  534.    new grass.trm
  535.  
  536. in release 162/164
  537.    set size [{no}square] x,y  - tries to plot with aspect ratio 1
  538.    - seems to work great for postscript
  539.    - please check with your favourite driver
  540.    - uses relative sizes of tics to determine required size.
  541.    posn for key, labels and arrows can be in one of 4 co-ordinate systems
  542.    - first_axes (default)
  543.    - second_axes (for plot..second)
  544.    - graph  (0,0 -> 1,1 = plotting area)
  545.    - screen (0,0 -> 1,1 = whole screen)
  546.    - arrows needn't have endpoints in same co-ords. see help set label
  547.    via is now a required keyword for fit
  548.    - fit f(x) 'file' ... via { 'file' | a,b,... }
  549.    - this is to avoid confusing 'file' with 'using-format-string'
  550.    win32 and 16-bit dos fixes
  551.    - I can compile with tc++, but get an overlay error at runtime.
  552.    new set of documentation programs (I haven't tried them)
  553.    various tweaks to makefile
  554.    changes to pslatex
  555.    - substitute .ps at _last_ . in filename
  556.    - accept font size of enclosing document as an option.
  557.    - dont forget to close aux file
  558.  
  559. in release 151
  560.  
  561.   linux security patch
  562.   can specify font for labels, etc (postscript only ? - I haven't tried this)
  563.   can specify linetype to draw grid / zeroaxes / arrows
  564.   emx terminal driver
  565.   first attempt at pipes for VMS and vector style - needs more work
  566.   l/b/r/t-margin  in place of xmargin - more control over size of margins
  567.   incompatible changes to polar mode:
  568.   - t is now the dummy variable, so x is width of plot as expected
  569.   - tics are not automatically on axes -   set {xy}tics axis nomirror
  570.   - grid is not automatically polar - set grid x [mx] polar [angle]
  571.   - no numbers on grid - they were always in degrees
  572.   second axes
  573.   - x2 and y2 are an independent pair of axes, but they inherit
  574.     ranges from x and y if no second data
  575.     - there can be problems with this, actually - if x2tics are not
  576.       shown, x2range is not autoextended to whole number of tics, so
  577.       same data might not have same range.
  578.   - set x2tics/y2tics/x2label/y2label
  579.   - set [no]log x2 / y2
  580.   - plot [first,] f(x), 'file', ..., second, g(x), ...
  581.   - get specify grid at any/all of x,y,x2,y2
  582.   - see electron.dem
  583.   set border <mask> - 12 bit binary number selects 12 sides of cube around splo
  584. t
  585.   can specify grid z, to get a grid on back wall of splot
  586.   set mxtics [<interval>|default] | set nomxtics
  587.   - set mxtics  gives auto for logscale, fixed for linear
  588.   binary, index and every keywords to datafiles.
  589.   - every also works with binary files
  590.   can use '-' as datafile for inline data (ends at line with e)
  591.   can use '' to mean reuse previous file
  592.   splot and fit now use datafile module
  593.   - FIT_SKIP no longer supported - use fit f(x) 'file' every n
  594.   can limit fit range using   fit [variable=min:max] f(variable) ...
  595.   set ticscale <major> [<minor>]
  596.   surface is clipped with no hidden line removal
  597.   - still to do contour and hidden-line surface
  598.   set {x|y|x2|y2} [axis|border] [no]mirror
  599.   - can put tics on border or axes
  600.   - mirror controls mirroring of tics on opposite axis
  601.     - no longer coupled to  set tics out  setiing.
  602.   No longer need to specify parametric mode for 3-column data files.
  603.   ranges automatically extended to whole number of tic intervals
  604.   - doesn't always manage to drop vertical from surface to corner of base
  605.     - workaround is either specify range or use  set border
  606.  
  607. patchlevel 140
  608. --------------
  609. I've probably missed a lot of features since I'm so used to them.
  610. Plus I never bothered with 3.5 so some of these may have been there.
  611. some of these may have made it into the documentation
  612. Here goes:
  613.  
  614.   fit f(x) 'file' via ...
  615.   read and plot time data  (timedat.dem)
  616.   set key [top|bottom|under] [left|right|out] [reverse] [box [<linetype>]]
  617.   set key title 'text'
  618.   Processing of escape sequences in "strings" but not 'strings'
  619.   - TeX users in particular advised to use ''
  620.   Multiline labels, etc, using "first\nsecond"
  621.   enhpost driver
  622.   call command (load with parameters)
  623.   x error bars. splines. boxes. [some may have been in 3.5]
  624.   pipes for amiga
  625.   the using patch   plot 'file' using spec:spec:...
  626.   - spec is either column number or (expression in $1, $2, ...)
  627.   new pslatex driver with postscript to aux file.
  628.   set pointsize <scale factor> on some terminals
  629.   doubles in  plot...using  format string - %lf
  630.   unlimited input line length and expression (action) table
  631.   minor tic-marks (like logscale but also for linear)
  632.   - also set grid [mx|my]
  633.  
  634.  
  635.  
  636. that's all I can think of for the moment...
  637.  
  638.    Q4.1: Does gnuplot have hidden line removal?
  639.           Version 3.5 supports hidden line removal on all platforms
  640.           except MS-DOS; use the command
  641.  
  642.  
  643.         set hidden3d
  644.  
  645.    If someone can solve the 64K DGROUP memory problem, gnuplot would
  646.           support hidden line removal on MS-DOS as well. Version 3.2
  647.           supports limited hidden line removal.
  648.  
  649.    Q4.2: Does gnuplot support bar-charts/histograms/boxes?
  650.           As of version 3.4, it does; use the style "with boxes" for bar
  651.           charts. To get filled boxes, you can try a modification by
  652.           Steve Cumming, available via ftp from
  653.           ftp://grebe.geog.ubc.ca/pub/gnuplot as box.tar.
  654.  
  655.    Q4.3: Does gnuplot support multiple y-axes on a single plot?
  656.           Yes, with two unofficial mods, multiplot.shar and borders.shar.
  657.           They can be obtained from
  658.           ftp://ftp.dartmouth.edu/pub/gnuplot/contrib/multi_woo.zip or
  659.           ftp://ftp.cygnus.edu/incoming/gpx38.zip.
  660.  
  661.           Also, 3.6 supports this capability.
  662.  
  663.    Q4.4: Can I put multiple plots on a single page?
  664.           Yes, with the multiplot.shar mod, or if you are running gnuplot
  665.           3.6. If you are using PostScript output, check out mpage, which
  666.           can be ftp'd from ftp.eng.umd.edu:pub/misc/mpage-2.tar.Z
  667.  
  668.    Q4.5: Can I put both data files and commands into a single file?
  669.           This feature is in gnuplot 3.6.
  670.  
  671.    Q4.6: Can I put Greek letters and super/subscripts into my labels?
  672.           You might try using the LaTeX terminal type and putting text
  673.           like \alpha_{3} into it.
  674.  
  675.           David Denholm has written a PostScript terminal which allows
  676.           for super/and subscripts, such as a^x or {/Symbol a }. Ftp to
  677.           sotona.phys.soton.ac.uk [152.78.192.42] and get enhpost.trm,
  678.           written by David Denholm and Matt Heffron. To install it,
  679.           follow the instructions at the top of the file, then recompile.
  680.           enhpost is also included in gnuplot 3.6.
  681.  
  682.    Q4.7: Can I do 1:1 scaling of axes?
  683.           Not easily in 3.5; in 3.6, you can use "set size square".
  684.  
  685.    Q4.8: Can I put tic marks for x and y axes into 3d plots?
  686.           In version 3.5, you can; use the "with boxes" option.
  687.  
  688.    Q4.9: Does gnuplot support a driver for <graphics format>?
  689.           To see a list of the available graphic drivers for your
  690.           installation of gnuplot, type "set term".
  691.  
  692.           Some graphics drivers are included in the normal distribution,
  693.           but are uncommented by default. If you want to use them, you'll
  694.           have to change ~gnuplot/term.h, and recompile.
  695.  
  696.    Q4.10: Can I put different text sizes into my plots?
  697.           If you use PostScript output, you can use Dave Denholm's and
  698.           Matt Heffron's updated PostScript driver,
  699.           /sotona.phys.soton.ac.uk:/enhpost.trm (see also Q4.6 ). Else,
  700.           use 3.6.
  701.  
  702.    Q4.11 How do I modify gnuplot, and apply 'patches'?
  703.           For this, you will need to recompile gnuplot.
  704.  
  705.           Modifications people make are either done by replacing files,
  706.           such as terminal drivers, or by 'patching'. If a file is a
  707.           replacement, it will probably tell you in its README or in the
  708.           lines at the beginning.
  709.  
  710.           To patch a file, you need Larry Wall's patch utility. On many
  711.           UNIX systems, it is already installed; do a man patch to check.
  712.           If it isn't, you'll have to get it; it can be found wherever
  713.           GNU software is archived.
  714.  
  715.    Q4.12 How do I skip data points?
  716.           By specifying ? as a data value, as in
  717.  
  718.  
  719.         1 2
  720.         2 3
  721.         3 ?
  722.         4 5
  723.  
  724.    Q4.13 How do I plot every nth point?
  725.           You can apply the patch point_skip from the contrib section
  726.           (see Q5.3 or, assuming you have awk installed on your system,
  727.           you can use the following line:
  728.  
  729.  
  730.         gnuplot> plot "< awk '{if(NR%5==0)print}' file.dat"
  731.  
  732.    plots every 5th line, and
  733.  
  734.  
  735.         gnuplot> plot "< awk '$0 !~ /^#/ {if(NR%40==0)print $1, $4}' file.dat"
  736.  
  737.    plots every 40th line while skipping commented lines.
  738.  
  739.  
  740.  
  741.   SECTION 5: MISCELLANEOUS
  742.  
  743.     Q5.1: I've found a bug, what do I do?
  744.           First, try to see whether it actually is a bug, or whether it
  745.           is a feature which may be turned off by some obscure set -
  746.           command.
  747.  
  748.           Next, see wether you have an old version of gnuplot; if you do,
  749.           chances are the bug has been fixed in a newer release.
  750.  
  751.           If, after checking these things, you still are convinced that
  752.           there is a bug, proceed as follows. If you have a fairly
  753.           general sort of bug report, posting to
  754.           comp.graphics.apps.gnuplot is probably the way to go. If you
  755.           have investigated a problem in detail, especially if you have a
  756.           context diff that fixes the problem, please e-email a report to
  757.           bug-gnuplot@dartmouth.edu. The bug-gnuplot list is for
  758.           reporting and collecting bug fixes, the
  759.           comp.graphics.apps.gnuplot newsgroup will be more help for
  760.           finding work arounds or actually solving gnuplot related
  761.           problems. If you do send in a bug report, be sure and include
  762.           the version of gnuplot (including patchlevel), terminal driver,
  763.           operating system, an exact description of the bug and input
  764.           which can reproduce the bug. Also, any context diffs should be
  765.           referenced against the latest official version of gnuplot if at
  766.           all possible.
  767.  
  768.    Q5.2: Can I use gnuplot routines for my own programs?
  769.           Yes. John Campbell <jdc@nauvax.ucc.nau.edu> has written
  770.           gplotlib, a version of gnuplot as C subroutines callable from a
  771.           C program. This is available as gplotlib.tar.Z on the machine
  772.           ftp.nau.edu in the directory /pub/gplotlib.tar.Z. This library
  773.           has been updated to be compatible with version 3.5.
  774.  
  775.    Q5.3: What extensions have people made to gnuplot? Where can I get
  776.           them?
  777.  
  778.  
  779.           Extensions are available from
  780.           ftp://ftp.dartmouth.edu/pub/gnuplot/contrib/ . It contains
  781.           the following files:
  782.  
  783.     Point Skips
  784.           + Data Filtering Instead of just having two params following
  785.             the style param, there are now 4:
  786.                o 1: line_type
  787.                o 2: point_type
  788.                o 3: point_skip - gives the number of data samples per
  789.                  plotted point
  790.                o 4: point_offs - gives the sample number on which to plot
  791.                  the first point
  792.         Thus points are plotted only for the samples n satisfying n =
  793.             point_skip*i + point_offs for some non-negative integer i.
  794.             From:
  795.             pixar!sun!prony.Colorado.EDU!clarkmp@ucbvax.berkeley.edu
  796.             (Michael Clark)
  797.  
  798.           + Point Skip with Awk With UNIX,
  799.  
  800. gnuplot> plot "< awk '{if(NR%5==0)print$0}' file.dat"
  801.         From: James Darrell McCauley, mccauley@ecn.purdue.edu
  802.  
  803.           + New Xlib mods. From: gregg hanna (gregor@kafka.saic.com)
  804.  
  805.     Vectors and Arrows
  806.           + Program to convert lines to vectors This program turns line
  807.             segments into line segments with a half-arrow at the head: by
  808.             uncommenting two lines below, the arrowhead will be a
  809.             triangle. optional arguments: size angle where size is a
  810.             fraction of each vector's magnitude and angle is in degrees
  811.             all data taken from standard input, and output to standard
  812.             output. typical invocation:
  813.  
  814. arrow 0.2 15 <vector.lin >vector.heads
  815.         From: andrew@jarthur.claremont.edu (Andrew M. Ross)
  816.  
  817.           + Vect2gp, an awk script to make gnuplot command script to draw
  818.             a vector field map. From: hiro@ice3.ori.u-tokyo.ac.jp
  819.             (Yasu-Hiro YAMAZAKI)
  820.  
  821.           + GNUPLOT to SIPP This is a "far from perfect" converter that
  822.             takes gnuplot table output and splits it in polygons. Then it
  823.             calls sipp to render it. You get sipp from
  824.             isy.liu.se:/pub/sipp or ask archie. From:
  825.             chammer@POST.uni-bielefeld.de (Carsten Hammer)
  826.  
  827.     Histograms and Pie Charts
  828.           + Histogram C program The short C program below is a filter
  829.             that calculates a histogram from a sequence of numbers and
  830.             prints the output in such a format that Gnuplot can plot the
  831.             histogram by the command sequence
  832.  
  833.  
  834.     !histogram < datain > tmp;
  835.     plot "tmp" with impulses
  836.  
  837.  
  838.             From: mustafa@seas.smu.edu (Mustafa Kocaturk)
  839.  
  840.           + HG is an automatic histogram generator. it reads a column of
  841.             data from an input file and emits a [log] histogram ks does
  842.             ks or chi^2 tests on a set of input arrays. you need the
  843.             "numerical recipes in C" library somewhere on your system to
  844.             link this one. I can not undertake to fix bugs or add
  845.             features, but I might do it if asked. From: Steve Cumming
  846.             stevec@geog.ubc.ca
  847.           + Piechart C program The short C program below formats data for
  848.             display as a piechart. From: mccauley@ecn.purdue.edu (James
  849.             Darrell McCauley)
  850.  
  851.     Interprocess Communications
  852.           + Notes of Windows Hooks From: Maurice
  853.             Castro,maurice@bruce.cs.monash.edu.au
  854.  
  855.           + Named Pipes Example From: dtaber@deathstar.risc.rockwell.com
  856.             (Don Taber)
  857.  
  858.           + PipeLib What the library does is set up to 20 programs going
  859.             (like gnuplot), then allows you to send to them as if the
  860.             program were typing on the command line. I've included a
  861.             brief set of docs after the source code, in latex format.
  862.             There is no facility to watch the output of a program. From:
  863.             ssclift@neumann.uwaterloo.ca (Simon Clift)
  864.  
  865.           + Popen example from lsqrfit The following function sends a
  866.             command to gnuplot. Gnuplot will execute the command just as
  867.             if you typed it at the gnuplot command line. This example is
  868.             adapted from my least squares fitting program which is
  869.             located at ftp.cdrom.com in pub/os2/2_x/unix/lsqrft14.zip.
  870.             Complete source is included. From: michael@krypton.mit.edu
  871.             (Michael Courtney)
  872.  
  873.     Multiple logical plots on a single page
  874.           + Gawk script for multiple encapsulated postscript on a page
  875.             It's slightly more flexible than mpage, because it changes
  876.             the aspect ratio of the plots; mpage according to the
  877.             documentation only allows 1, 2, 4, or 8 plots on a page. This
  878.             script works for unix with encapsulated postscript (eps)
  879.             output. It should work with gawk or nawk, although I've only
  880.             tested it with gawk. (Gawk is GNU's version of awk and is
  881.             available from prep.ai.mit.edu.) You just specify how many
  882.             rows and columns of plots you want and it does the rest. For
  883.             example, gnuplot_eps rows=3 cols=2 *.eps | lpr will print all
  884.             eps files in your current directory with 6 on a page. Also,
  885.             see the comments in the file. From:
  886.             holt@goethe.cns.caltech.edu (Gary Holt)
  887.  
  888.           + Sed script for multiple encapsulated postscript on a page You
  889.             have MULTIPLE postscript files each containing a single plot.
  890.             From: wgchoe@scoupe.postech.ac.kr (Choe Won Gyu)
  891.  
  892.           + Massive patch with add multiplotcapability to all devices and
  893.             a lot more. The reason it is offered in this form is because
  894.             the original multiplot.pat did not patch correctly into
  895.             gnuplot version 3.5. This mod also add borders options,
  896.             financial plots, multiple line titles and other asundry
  897.             items. Use at your own risk. Look at the top of makefile.r
  898.             for a more complete list of changes.
  899.  
  900.             From: Alex Woo, woo@playfair.stanford.edu
  901.  
  902.     lvs.zip
  903.         This contains miscellaneous, modifications, which include:
  904.           + Label positioning using either plot or device-relative
  905.             coodinates
  906.           + Portability to Irix-5.2 and Irix-5.3
  907.           + The "thru" keyword has been extended to include "thrux" for
  908.             the X - Coordinate
  909.           + Capability to read a ordinary Fortran-style unformatted file
  910.           + A Perl script for better handling of eps
  911.           + Modifications to docs/doc2info to generate "next", "prev",
  912.             and "up" data for each node.
  913.           + Changes in the documentation to reflect the above.
  914.  
  915.     Miscellaneous Mods
  916.           + Congp3d3 is a preprocessor to draw contour plots on irregular
  917.             regions. From: mrb2@nrc.gov (Margaret Rose Byrne)
  918.  
  919.           + Sockpipe is a socket based pipe needed for the Stardent OS.
  920.             From: Mike Hallesy, Stardent Computer Product Support,
  921.             hal@stardent.com
  922.  
  923.           + Time Series is a patch to add multiline titles and labels,
  924.             time series x and y data and tic marks, and automatic
  925.             resizing of plots and much more. From: Hans Olav Eggestad,
  926.             olav@jordforsk.nlh.no
  927.  
  928.     Other Operationing Systems
  929.           + MacIntosh Port of Version 3.2 From: Noboru Yamamoto,
  930.             sun!kekvax.kek.jp!YAMAMOTO@pixar.com
  931.  
  932.           + MacIntosh Port of Version 3.5 From: laval@londres.cma.fr
  933.             (Philippe LAVAL)
  934.  
  935.           + OS-9 Port of Version 3.2
  936.  
  937.  
  938.    Q5.4: Can I do heavy - duty data processing with gnuplot?
  939.           Gnuplot alone is not suited very well for this. One thing you
  940.           might try is fudgit, an interactive multi-purpose fitting
  941.           program written by Martin-D. Lacasse
  942.           (isaac@frodo.physics.mcgill.ca). It can use gnuplot as its
  943.           graphics back end and is available from ftp.physics.mcgill.ca
  944.           in /pub/Fudgit/fudgit_2.33.tar.Z [132.206.9.13], and from the
  945.           main Linux server, tsx-11.mit.edu [18.172.1.2] and its numerous
  946.           mirrors around the world as
  947.           /pub/linux/sources/usr.bin/fudgit-2.33.tar.z. Versions are
  948.           available for AIX, Data General, HP-UX, IRIX 4, Linux, NeXT,
  949.           Sun3, Sun4, Ultrix, OS/2 and MS-DOS. The MS-DOS version is
  950.           available on simtel20 mirrors (simtel20 itself has closed down)
  951.           in the "math" subdirectory as fudg_231.zip.
  952.  
  953.           Carsten Grammes has written a fitting program which goes
  954.           together with gnuplot; it is called gnufit and is available
  955.           from the official gnuplot sites, as the files gnufit12.info,
  956.           gnufit12.tar.gz (source) and gft12dos.zip (MS-DOS). It has been
  957.           merged into gnuplot 3.6.
  958.  
  959.           Michael Courtney has written a program called lsqrft, which
  960.           uses the Levenberg - Marquardt - Algorithm for fitting data to
  961.           a function. It is avialiable from ftp.cdrom.com as
  962.           /pub/os2/2_x/unix/lsqrft13.zip; sources, which should compile
  963.           on Unix, and executables for MS-DOS and OS/2 2.x are included.
  964.           There is an interface to the OS/2 presentation manager.
  965.  
  966.           You might also want to look at the applications developed by
  967.           the Software Tools Group (STG) at the National Center for
  968.           Supercomputing Applications. Ftp to ftp.ncsa.uiuc.edu
  969.           [141.142.20.50] and get the file README.BROCHURE for more
  970.           information.
  971.  
  972.           You can also try pgperl, an integration of the PGPLOT plotting
  973.           package with Perl 5. Information can be found at
  974.           http://www.ast.cam.ac.uk/~kgb/pgperl.html, the source is
  975.           available from ftp://ftp.ast.cam.ac.uk/pub/kgb/pgperl/ or
  976.           ftp://linux.nrao.edu/pub/packages/pgperl/.
  977.  
  978.           Another possibility is Octave. To quote from its README: Octave
  979.           is a high-level language, primarily intended for numerical
  980.           computations. It provides a convenient command line interface
  981.           for solving linear and nonlinear problems numerically.
  982.  
  983.           The latest released version of Octave is always available via
  984.           anonymous ftp from bevo.che.wisc.edu in the directory
  985.           /pub/octave.
  986.  
  987.    Q5.5: I have ported gnuplot to another system, or patched it. What do
  988.           I do?
  989.           If your patch is small, mail it to bug-gnuplot@dartmouth.edu,
  990.           with a thorough description of what the patch is supposed to
  991.           do, which version of gnuplot it is relative to, etc. Also, you
  992.           can send notification of the patch to the FAQ maintainer, if
  993.           you want a mention. Please don't send the patch itself to me
  994.           :-)
  995.  
  996.           If your modifications are extensive (such as a port to another
  997.           system), upload your modifications to
  998.           ftp://ftp.dartmouth.edu/pub/dropoff. Please drop a note to
  999.           David.Kotz@dartmouth.edu, the maintainer of the gnuplot
  1000.           subdirectory there, plus a note to bug-gnuplot@dartmouth.edu.
  1001.  
  1002.    Q5.6: I want to help in developing gnuplot 3.6. What can I do?
  1003.           Join the gnuplot beta test mailing list by sending a mail
  1004.           containing the line
  1005.  
  1006.  
  1007. subscribe info-gnuplot-beta
  1008.  
  1009.    in the body (not the subject) of the mail to Majordomo@Dartmouth.EDU.
  1010.  
  1011.  
  1012.  
  1013.   SECTION 6: MAKING LIFE EASIER
  1014.  
  1015.     Q6.1: How do I plot two functions in non - overlapping regions?
  1016.           Use a parametric plot. An example:
  1017.  
  1018.  
  1019.         set parametric
  1020.         a=1
  1021.         b=3
  1022.         c=2
  1023.         d=4
  1024.         x1(t) = a+(b-a)*t
  1025.         x2(t) = c+(d-c)*t
  1026.         f1(x) = sin(x)
  1027.         f2(x) = x**2/8
  1028.         plot [t=0:1] x1(t),f1(x1(t)) title "f1", x2(t), f2(x2(t)) title "f2"
  1029.  
  1030.    Q6.2: How do I run my data through a filter before plotting?
  1031.           If your system supports the popen() function, as Unix does, you
  1032.           should be able to run the output through another process, for
  1033.           example a short awk program, such as
  1034.  
  1035.  
  1036.         gnuplot> plot "< awk ' { print $1, $3/$2 } ' file.in"
  1037.  
  1038.    Unfortunately, in 3.2, there is a rather short limitation on the
  1039.           maximum argument length, so your command line may be truncated
  1040.           (usually, this will mean that awk cannot find the filename).
  1041.           Also, you may need to escape the $ - characters in your awk
  1042.           programs.
  1043.  
  1044.           As of version 3.4, gnuplot includes the thru - keyword for the
  1045.           plot command for running data files through a gnuplot - defined
  1046.           function.
  1047.  
  1048.           You can also get divhack.patch from
  1049.           sotona.phys.soton.ac.uk[152.78.192.42] via anonymous ftp. It
  1050.           allows expressions of the kind
  1051.  
  1052.  
  1053.         gnuplot> plot "datafile" using A:B:C
  1054.  
  1055.    where A,B,C,... are now either a column number, as usual, or an
  1056.           arbitrary expression enclosed in ()'s, and using $1,$2,etc to
  1057.           access the data columns.
  1058.  
  1059.    Q6.3: How do I make it easier to use gnuplot with LaTeX?
  1060.           There is a set of LaTeX macros and shell scripts that are meant
  1061.           to make your life easier when using gnuplot with LaTeX. This
  1062.           package can be found on ftp.dartmouth.edu [129.170.16.54] in
  1063.           pub/gnuplot/latex.shar, by David Kotz. For example, the program
  1064.           "plotskel" can turn a gnuplot-output file plot.tex into a
  1065.           skeleton file skel.tex, that has the same size as the original
  1066.           plot but contains no graph. With the right macros, the skeleton
  1067.           can be used for preliminary LaTeX passes, reserving the full
  1068.           graph for later passes, saving tremendous amounts of time.
  1069.  
  1070.    Q6.4: How do I save and restore my settings?
  1071.           Use the "save" and "load" commands for this; see "help save"
  1072.           and "help load" for details.
  1073.  
  1074.    Q6.5: How do I plot lines (not grids) using splot?
  1075.           If the data in a data file for splot is arranged in such a way
  1076.           that each one has the same number of data points (using blank
  1077.           lines as delimiters, as usual), splot will plot the data with a
  1078.           grid. If you want to plot just lines, use a different number of
  1079.           data entries (you can do this by doubling the last data point,
  1080.           for example). Don't forget to set parametric mode, of course.
  1081.  
  1082.    Q6.6: How do I plot a function f(x,y) which is bounded by other
  1083.           functions in the x-y plain?
  1084.           An example:
  1085.  
  1086.  
  1087.         f(x,y) = x**2 + y **2
  1088.         x(u) = 3*u
  1089.         yu(x) = x**2
  1090.         yl(x) = -x**2
  1091.         set parametric
  1092.         set cont
  1093.         splot [0:1] [0:1] u,yl(x(u))+(yu(x(u)) - yl(x(u)))*v,\
  1094.         f(x(u), (yu(x(u)) - yl(x(u)))*v)
  1095.  
  1096.    Q6.7: How do I get rid of <feature in a plot>?
  1097.           Usually, there is a set command to do this; do a
  1098.  
  1099.  
  1100.         gnuplot> ?set no
  1101.  
  1102.    for a short overview.
  1103.  
  1104.    Q6.8: How do I call gnuplot from my own programs?
  1105.           Here's code which works for a UNIX system, using (efficient)
  1106.           named pipes.
  1107.  
  1108.  
  1109. #include <sys/types.h>
  1110. #include <sys/stat.h>
  1111. #include <stdlib.h>
  1112. #include <stdio.h>
  1113. #include <math.h>
  1114. #include <unistd.h>
  1115.  
  1116. #define PANIC(a) do { \
  1117.                 perror(a); \
  1118.                 if (temp_name) unlink(temp_name);\
  1119.                 exit(1);\
  1120.         } while(0)
  1121.  
  1122. int main() {
  1123.     FILE *command,*data;
  1124.     char *temp_name = NULL;
  1125.     double a,b;
  1126.     int i;
  1127.  
  1128.     if ((temp_name = tmpnam((char *) 0)) == 0) PANIC("tmpnam failed");
  1129.     if(mkfifo(temp_name, S_IRUSR | S_IWUSR) != 0) PANIC("mkfifo failed");
  1130.     command = popen("gnuplot","w");
  1131.     fprintf(command,"plot \"%s\" with lines\n",temp_name); fflush(command);
  1132.     data = fopen(temp_name,"w");
  1133.     for (i=0; i<20; i++) {
  1134.         a = i/10.0;
  1135.         b = sin(a);
  1136.         fprintf(data,"%f %f\n",a,b);
  1137.     }
  1138.     fclose(data);
  1139.     fprintf(stderr,"press enter to continue..."); fflush(stderr);
  1140.     getchar();
  1141.  
  1142.     fprintf(command,"plot \"%s\" with lines\n",temp_name); fflush(command);
  1143.     data = fopen(temp_name,"w");
  1144.     for (i=0; i<20; i++) {
  1145.         a = i/10.0;
  1146.         b = cos(a);
  1147.         fprintf(data,"%f %f\n",a,b);
  1148.     }
  1149.     fclose(data);
  1150.     fprintf(stderr,"press enter to continue..."); fflush(stderr);
  1151.     getchar();
  1152.     pclose(command);
  1153.     unlink(temp_name);
  1154.     return 0;
  1155. }
  1156.  
  1157.    Here's code for OS/2, again using named pipes; I'm unable to check
  1158.           this out myself. This code is care of fearick@physci.uct.ac.za
  1159.           (Roger Fearick).
  1160.  
  1161.  
  1162. #include <stdio.h>
  1163. #define INCL_DOS
  1164. #define INCL_DOSPROCESS
  1165. #define INCL_DOSNMPIPES
  1166. #include <os2.h>
  1167.  
  1168. main()
  1169.     {
  1170.     HPIPE hpipe ;
  1171.     FILE *hfile, *hgnu ;
  1172.         /* create a named pipe. Use NP_WAIT so that DosConnect...
  1173.            blocks until client (gnuplot) opens, and client reads
  1174.            are blocked until data is available */
  1175.     DosCreateNPipe( "\\pipe\\gtemp",
  1176.                     &hpipe,
  1177.                     NP_ACCESS_OUTBOUND,
  1178.                     NP_WAIT|NP_TYPE_BYTE|1,
  1179.                     256,
  1180.                     256,
  1181.                     -1 ) ;
  1182.         /* use stream i/o */
  1183.     hfile = fdopen( hpipe, "w" ) ;
  1184.  
  1185.         /* start gnuplot; use unbuffered writes so we don't need to
  1186.            flush buffer after a command */
  1187.     hgnu = popen( "gnuplot", "w" ) ;
  1188.     setvbuf( hgnu, NULL, _IONBF, 0 ) ;
  1189.  
  1190.         /* plot a set of data */
  1191.  
  1192.     fprintf( hgnu, "plot '/pipe/gtemp'\n" ) ;  /* issue plot command */
  1193.     DosConnectNPipe( hpipe ) ;              /* wait until 'file' opened */
  1194.     fprintf( hfile, "1 1\n" ) ;             /* write data to 'file' */
  1195.     fprintf( hfile, "2 2\n" ) ;
  1196.     fprintf( hfile, "3 3\n" ) ;
  1197.     fprintf( hfile, "4 4\n" ) ;
  1198.     fflush( hfile ) ;                       /* flush buffer forces read */
  1199.     DosSleep( 500 ) ;                       /* allow gnuplot to catch up */
  1200.     DosDisConnectNPipe( hpipe ) ;           /* disconnect this session */
  1201.     fprintf( hgnu, "pause -1\n" ) ;         /* admire plot */
  1202.  
  1203.         /* plot another set of data */
  1204.  
  1205.     fprintf( hgnu, "plot '/pipe/gtemp'\n" ) ;
  1206.     DosConnectNPipe( hpipe ) ;
  1207.     fprintf( hfile, "1 4\n" ) ;
  1208.     fprintf( hfile, "2 3\n" ) ;
  1209.     fprintf( hfile, "3 2\n" ) ;
  1210.     fprintf( hfile, "4 1\n" ) ;
  1211.     fflush( hfile ) ;
  1212.     DosSleep( 500 ) ;
  1213.     DosDisConnectNPipe( hpipe ) ;
  1214.     fprintf( hgnu, "pause -1\n" ) ;
  1215.  
  1216.     DosClose( hpipe ) ;
  1217.     pclose( hgnu ) ;
  1218.     }
  1219.  
  1220.    ; The above code works for gnuplot 3.5. In gnuplot 3.6, this can be
  1221.           greatly simplified, since data can be fed 'inline, as in
  1222.  
  1223.  
  1224. plot '-' w l
  1225. 1 1
  1226. 2 3
  1227. 3 4
  1228. e
  1229.  
  1230.  
  1231.  
  1232.   SECTION 7: KNOWN PROBLEMS
  1233.  
  1234.     Q7.1: Gnuplot is not plotting any points under X11! How come?
  1235.           Very probably, you still are using an old version of
  1236.           gnuplot_x11. Remove that, then do a full installation.
  1237.  
  1238.           On VMS, you need to make several symbols:
  1239.  
  1240.  
  1241.         $ gnuplot_x11 :== $disk:[directory]gnuplot_x11
  1242.         $ gnuplot :== $disk:[directory]gnuplot.exe
  1243.         $ def/job GNUPLOT$HELP disk:[directory]gnuplot.hlb
  1244.  
  1245.    Then run gnuplot from your command line, and use
  1246.  
  1247.  
  1248.         gnuplot> set term x11
  1249.  
  1250.    Q7.2: My isoline data generated by a Fortran program is not handled
  1251.           correctly. What can I do?
  1252.           One known cause for this is the use of list-directed output (as
  1253.           in WRITE(10,*) for generating blank lines. Fortran uses ASA
  1254.           carriage control characters, and for list - directed output
  1255.           this results in a space being output before the newline.
  1256.           Gnuplot does not like this. The solution is to generate blank
  1257.           lines using formatted output, as in WRITE(10,'()'). If you use
  1258.           carriage return files in VMS Fortran, you may have to open the
  1259.           file with OPEN(...,CARRIAGECONTROL='DTST') or convert it using
  1260.           the DECUS utility ATTRIB.EXE:
  1261.  
  1262.  
  1263.         VMS> ATTRIB/RATTRIB=IMPDTED FOR010.DAT
  1264.  
  1265.    Q7.3: Why does gnuplot ignore my very small numbers?
  1266.           Gnuplot treats all numbers less than 1e-08 as zero, by default.
  1267.           Thus, if you are trying to plot a collection of very small
  1268.           numbers, they may be plotted as zero. Worse, if you're plotting
  1269.           on a log scale, they will be off scale. Or, if the whole set of
  1270.           numbers is "zero", your range may be considered empty:
  1271.  
  1272.  
  1273.         gnuplot> plot 'test1'
  1274.         Warning: empty y range [4.047e-19:3e-11], adjusting to [-1:1]
  1275.         gnuplot> set yrange [4e-19:3e-11]
  1276.         gnuplot> plot 'test1'
  1277.                      ^
  1278.          y range is less than `zero`
  1279.  
  1280.    The solution is to change gnuplot's idea of "zero":
  1281.  
  1282.  
  1283.         gnuplot> set zero 1e-20
  1284.  
  1285.    For more information,
  1286.  
  1287.  
  1288.         gnuplot> help set zero
  1289.  
  1290.    Q7.4: Gnuplot is plotting nothing when run via gnuplot <filename>!
  1291.           What can I do?
  1292.           Put a pause -1 after the plot command in the file.
  1293.  
  1294.    Q7.5: My formulas are giving me nonsense results! What's going on?
  1295.           Gnuplot does integer, and not floating point, arithmetic on
  1296.           integer expressions. For example, the expression 1/3 evaluates
  1297.           to zero. If you want floating point expressions, supply
  1298.           trailing dots for your floating point numbers. Example:
  1299.  
  1300.  
  1301.         gnuplot> print 1/3
  1302.                 0
  1303.         gnuplot> print 1./3.
  1304.                 0.333333
  1305.  
  1306.    This way of evaluating integer expressions is shared by both C and
  1307.           Fortran.
  1308.  
  1309.    Q7.6: My Linux gnuplot complains about a missing gnuplot_x11. What is
  1310.           wrong?
  1311.           The binary gnuplot distribution from sunsite.unc.edu and its
  1312.           mirrors in Linux/apps/math/gplotbin.tgz is missing one
  1313.           executable that is necessary to access the x11 terminal. Please
  1314.           install gnuplot from another Linux distribution, e.g.
  1315.           Slackware.
  1316.  
  1317.   SECTION 8: CREDITS
  1318.  
  1319.    This list was initially compiled by John Fletcher with contributions
  1320.    from Russell Lang, John Campbell, David Kotz, Rob Cunningham, Daniel
  1321.    Lewart and Alex Woo. Reworked by Thomas Koenig from a draft by Alex
  1322.    Woo, with corrections and additions from Alex Woo, John Campbell,
  1323.    Russell Lang, David Kotz and many corrections from Daniel Lewart; Axel
  1324.    Eble and Jutta Zimmermann helped with the conversion to HTML.
  1325.  
  1326.  
  1327.  
  1328.     Thomas Koenig, ig25@rz.uni-karlsruhe.de, 1994-03-28
  1329.